package com.atguigu.gulimall.order;

import org.springframework.amqp.rabbit.annotation.EnableRabbit;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.openfeign.EnableFeignClients;
import org.springframework.context.annotation.EnableAspectJAutoProxy;
import org.springframework.session.data.redis.config.annotation.web.http.EnableRedisHttpSession;
//import com.alibaba.cloud.seata.GlobalTransactionAutoConfiguration;

/**
 * 使用RabbitMQ
 * 1、引入amqp场景，RabbitAutoConfiguration就会自动生效
 * 2、给容器中自动配置了 RabbitTemplate、AmqpAdmin、CachingConnectionFactory、RabbitMessagingTemplate
 *      所有的属性配置参考：RabbitProperties  ，@ConfigurationProperties(prefix = "spring.rabbitmq")
 * 3、给配置文件中配置： "spring.rabbitmq"开头的信息
 * 4、开启功能   @EnableRabbit
 * 5、监听消息,使用@RabbitListener,必须开启@EnableRabbit才有
 * * @RabbitListener:可以标注在类+方法上[监听哪些队列即可];
 * * @RabbitHandler:可以标注在方法上[重载区分不同的消息];
 *
 * Seata控制分布式事务
 *  1）、每一个微服务必须创建undo_Log
 *  2）、安装事务协调器：seate-server
 *  3）、整合
 *      1、导入依赖
 *      2、解压并启动seata-server：
 *          registry.conf:注册中心配置    修改 registry ： nacos
 *      3、所有想要用到分布式事务的微服务使用seata DataSourceProxy 代理自己的数据源
 *      4、每个微服务，都必须导入   registry.conf   file.conf
 *          vgroup_mapping.{application.name}-fescar-server-group = "default"
 *      5、启动测试分布式事务
 *      6、给分布式大事务的入口标注@GlobalTransactional
 *      7、每一个远程的小事务用@Trabsactional
 */

@EnableAspectJAutoProxy(exposeProxy = true)     //开启了aspect动态代理模式,对外暴露代理对象
@EnableRedisHttpSession     //开启springsession
@EnableRabbit//需要监听消息时才标注
@EnableFeignClients
@EnableDiscoveryClient
@SpringBootApplication
//@SpringBootApplication(exclude = GlobalTransactionAutoConfiguration.class)//添加3 gulimall的
public class GulimallOrderApplication {

    public static void main(String[] args) {
        SpringApplication.run(GulimallOrderApplication.class, args);
    }

}
